class Solution {
public:
    void row(vector<vector<int>>& matrix, int x) {
        for (int j = 0; j < matrix[0].size(); ++j) {
            if (matrix[x][j] !=0)
                matrix[x][j] = -999;
        }
    }
    void col(vector<vector<int>>& matrix, int y) {
        for (int j = 0; j < matrix.size(); ++j) {
            if (matrix[j][y] != 0)
                matrix[j][y] = -999;
        }
    }
    void setZeroes(vector<vector<int>>& matrix) {
        // 这个感觉就是染色法 没啥说的
        // 如果是0 那么行和列都染成 -1 最后再染成0就好了
        for (int i = 0; i < matrix.size(); ++i) {
            for (int j = 0; j < matrix[0].size(); ++j) {
                if (matrix[i][j] == 0) {
                    row(matrix, i);
                    col(matrix, j);
                }
            }
        }
        for (int i = 0; i < matrix.size(); ++i) {
            for (int j = 0; j < matrix[0].size(); ++j) {
                if (matrix[i][j] == -999) {
                    matrix[i][j] = 0;
                
                }
            }
        }
    }
};
